<template>
    <app-layout>
        <view v-if="!goods" class="u-goods-detail"></view>
        <view v-if="goods">
            <app-goods-banner :pic-list="goods.pic_url"
                             :share="goods.share"
                             :goods_id="goods.id"
                             :video-url="goods.video_url"
            ></app-goods-banner>
            <view class="other-info">
                <view class="t-omit-two goods-name">{{goods.name}}</view>
                <view v-if="goods.subtitle" class="goods-subtitle">
                    <view class="t-omit-three">{{goods.subtitle}}</view>
                </view>
                <view class='price main-between'>
                   <view>
                       <view :style="{'color': getTheme.color}">
                           {{goods.integralMallGoods.integral_num}}积分
                           <template v-if="goods.price > 0">+￥{{goods.price}}元</template>
                       </view>
                       <view class='original' v-if="isUnderlinePrice == 1">￥{{goods.original_price}}</view>
                   </view>
                    <view @click="shareClick" :style="{'background-color': getTheme.background}" class="share dir-left-nowrap main-center cross-center">
                        <image class="share-image box-grow-0" src="/static/image/icon/icon-share-white.png"></image>
                        <view class="share-text box-grow-0">分享</view>
                    </view>
               </view>
			   <view>
				   <bd-info-extra :goods="goods" :theme="getTheme" :unit="goods.unit" :min-number="goods.min_number" :limit-buy="goods.limit_buy"></bd-info-extra>
			   </view>
            </view>
            <!--商品优惠券-->
            <bd-coupon @change="setCoupon" :theme="getTheme" :coupons="goods.goods_coupon_center"></bd-coupon>
            <bd-xbc
                :coAttr="is_open"
                :attr-list="selectAttr && selectAttr.attr_list"
                :type="goods.type"
                :guarantee-title="goods.guarantee_title"
                :guarantee-pic="goods.guarantee_pic"
                :param_content="goods.param_content"
                :param_name="goods.param_name"
                :services="goods.services"
                :attr-groups="goods.attr_groups"
                :goods-stock="goods.goods_stock"
                @openAttr="clickAttr"
            ></bd-xbc>
            <!--商品信息-->
            <bd-hc
                :integral="goods.goods_marketing_award.integral"
                :coupon="goods.goods_marketing_award.coupon"
                :card="goods.goods_marketing_award.card"
                :balance="goods.goods_marketing_award.balance"
                :theme="getTheme"
            ></bd-hc>
            <bd-kb
                :limit="goods.goods_marketing.limit"
                :express="goods.express"
                :shipping="goods.goods_marketing.shipping"
                :pickup="goods.goods_marketing.pickup"
            ></bd-kb>
            <bd-detail :detail="goods.detail"></bd-detail>
            <!-- 底部空格 -->
            <view class="safe-area-inset-bottom">
               <view class="u-bottom-height"></view>
            </view>
	        <view v-if="is_open == 1" class="safe-area-inset-bottom u-bottom-fixed">
               <view class="bd-bottom dir-left-nowrap cross-center">
                   <view class="bd-back dir-top-nowrap main-center cross-center box-grow-0" @click="back">
                       <image class="bd-icon" src="/static/image/icon/index.png"></image>
                       <text class="bd-text">首页</text>
                   </view>
                   <bd-service :name="goods.name" :url="webUrl"></bd-service>
                    <view class="box-grow-1 bd-btn bd-oversell-btn bd-btn-color" @click="clickAttr" :style="{'background': getTheme.background_gradient_btn,'color': getTheme.main_text,'opacity': '0.5'}" v-if="!goods.buy_goods_auth">
                        <app-jump-button :open_type="buy_goods_auth_link.open_type" :url="buy_goods_auth_link.new_link_url" :params="buy_goods_auth_link.params">
                            {{buy_goods_auth_text}}
                        </app-jump-button>
                    </view>
                   <view v-else-if="goods.goods_stock === 0" class="box-grow-1 bd-btn bd-oversell-btn bd-btn-color" >
                       已售罄
                   </view>
                   <view
                       v-else
                       @click="clickAttr"
                       :style="{'background': goods.buy_goods_auth ? getTheme.background_gradient_btn : '#999999'}"
                       class="bd-btn box-grow-1 bd-btn-color">
                    立即兑换
                   </view>
               </view>
            </view>
			<!--快捷导航-->
			<app-quick-navigation></app-quick-navigation>
        </view>
        <app-close v-if="showClose" :modal="false" @update="getMall"></app-close>
        <app-share-qr-code
            v-if="goods && goods.id > 0"
            v-model="shareShow"
            :url="shareUrl"
            :has-poster-nav="true"
            :poster-config="poster_config + `&goods_id=` + goods.id"
            :poster-generate="poster_generate + `&goods_id=` + goods.id"
            :goods="goods"
            @share="hShareAppMessage"
        ></app-share-qr-code>
        <u-attr
            v-if="goods && goods.id > 0"
            v-model="attrShow"
            :theme="getTheme"
            :checked="selectAttr"
            :goods="goods"
            @check="onAttr"
            :rightFunc="true"
            @rightFunc="rightFunc"
            :is_show_left="false"
            rightText="立即兑换"
            sign="integral_mall"
        >
            <view slot="priceBefore" >
                <template v-if="selectAttr">
                    {{selectAttr.extra.value}}{{selectAttr.extra.name}}
                </template>
                <template v-else>
                    {{goods.integralMallGoods.integral_num}}积分
                </template>
            </view>
        </u-attr>
    </app-layout>
</template>

<script>
	import {mapGetters, mapState} from "vuex";
    import appGoodsBanner from "../../../components/page-component/goods/app-goods-banner.vue";
    import appRecommendedProduct from "../components/app-recommended-product.vue";
    import appShareQrCode from '../../../components/page-component/app-share-qr-code-poster/app-share-qr-code-poster.vue';
    import uAttr from '../../../components/page-component/goods/u-attr.vue';
    import appClose from '@/components/basic-component/app-close/app-close.vue';
    import bdInfo from '@/components/page-component/goods/bd-info';
    import bdCoupon from '@/components/page-component/goods/bd-coupon.vue';
    import bdXbc from '@/components/page-component/goods/bd-xbc.vue';
    import bdKb from '@/components/page-component/goods/bd-kb.vue';
    import bdHc from '@/components/page-component/goods/bd-hc.vue';
    import bdDetail from '@/components/page-component/goods/bd-detail.vue';
    import bdService from '@/components/page-component/goods/bd-service.vue';
	import bdInfoExtra from '@/components/page-component/goods/bd-info-extra.vue';
    import appQuickNavigation from "@/components/page-component/app-quick-navigation/app-quick-navigation.vue";

    export default {
        name: "goods",
        components: {
            appGoodsBanner,
            appShareQrCode,
            appRecommendedProduct,
            uAttr,
            appClose,
            bdInfo,
            bdCoupon,
            bdXbc,
            bdKb,
            bdHc,
            bdDetail,
            bdService,
			bdInfoExtra,
			appQuickNavigation
        },
        data() {
            return {
                showClose: false,
                is_open: 0,
                goods: null,
                selectAttr: null,
                recommend_list: null,
                shareShow: false,
                shareUrl: null,
                attrShow: false,
                loading: false,
                webUrl: '',
                poster_config: this.$api.integral_mall.poster_config,
                poster_generate: this.$api.integral_mall.poster_generate,
				disable: 'disable'
            };
        },
        computed: {
            ...mapState({
                mall: state => state.mallConfig.mall,
                buy_goods_auth_link: state => state.mallConfig.mall.setting.buy_goods_auth_link,
                buy_goods_auth_text: state => state.mallConfig.mall.setting.buy_goods_auth_text,
                isUnderlinePrice: state => state.mallConfig.mall.setting.is_underline_price,
            }),
			...mapGetters('mallConfig', {
				getTheme: 'getTheme',
			})
        },
        onShow() {
            this.showClose = false;
            setTimeout(()=>{
                this.showClose = true;
            })
        },
        onLoad(options) { this.$commonLoad.onload(options);
            this.webUrl = '/plugins/integral_mall/goods/goods?goods_id=' + options.goods_id;
            // #ifdef MP-WEIXIN
            wx.showShareMenu({
              menus: ['shareAppMessage', 'shareTimeline']
            })
            // #endif
            this.loadData(options.goods_id);
        },
        // #ifdef MP-WEIXIN
        onShareTimeline() {
          // 分享朋友圈beta
          return this.$shareTimeline({
            title: this.goods.app_share_title ? this.goods.app_share_title: this.goods.name,
            imageUrl: this.goods.pic_url[0].pic_url,
            query: {
                goods_id: this.goods.id
            } // 此处填写页面的参数
          });
        },
        // #endif
        // #ifdef MP
        onShareAppMessage() {
           return this.hShareAppMessage();
        },
        // #endif
        methods: {
            hShareAppMessage(s= false){
                return this.$shareAppMessage({
                    title: this.goods.app_share_title ? this.goods.app_share_title: this.goods.name,
                    imageUrl: this.goods.app_share_pic ? this.goods.app_share_pic: this.goods.cover_pic,
                    path: "/plugins/integral_mall/goods/goods",
                    desc: this.goods.subtitle,
                    params: {
                        goods_id: this.goods.id
                    }
                }, s);
            },
            getMall(e) {
                this.is_open = e.is_open;
            },
            loadData(id) {
                this.$showLoading();
                this.$request({
                    url: this.$api.integral_mall.goods_detail,
                    data: {
                        id: id
                    }
                }).then(response => {
                    this.$hideLoading();
                    let {code, data, msg} = response;
                    if (code === 0) {
                        this.goods = data.detail;
                        this.shareUrl = this.$api.integral_mall.poster + '&goods_id=' + id;
                        this.goods.id = id;
                        this.loading = true;
                        // #ifdef H5
                        this.hShareAppMessage();
                        // #endif
                    } else {
                        uni.showModal({
                            title: '提示',
                            content: msg,
                            showCancel: false
                        });
                    }
                }).catch(() => {
                    this.$hideLoading();
                });
            },
            onAttr({item}) {
                this.selectAttr = item;
            },
            shareClick() {
                this.shareShow = true;
            },
            back() {
                uni.redirectTo({
                    url: '/pages/index/index'
                });
            },
            clickAttr() {
				if (!this.goods.buy_goods_auth) {
                    this.$tips.showToast({
                        title: '您暂无权限购买该商品',
                        icon: 'none'
                    });
                    return;
				}
                this.attrShow = true;
            },
			setCoupon(index) {
				this.$set(this.goods.goods_coupon_center[index], 'is_receive', 1);
			},
            rightFunc: function(data) {
                uni.navigateTo({
                    url: `/pages/order-submit/order-submit?mch_list=${JSON.stringify([data])}&preview_url=${encodeURIComponent(this.$api.integral_mall.order_preview)}&submit_url=${encodeURIComponent(this.$api.integral_mall.order_submit)}`
                });
            }
        }
    }
</script>

<style scoped lang="scss">
    .preventTouchMove{
        top: 0;
        left: 0;
        width: 100%;
        overflow: hidden;
        position: fixed;
        z-index: 0;
    }
    .other-info {
        width: 702upx;
        background-color: #fff;
        padding: #{20rpx};
        margin: 24upx 24upx 0 24upx;
        border-radius: 15upx;
    }
    .goods-name {
        background-color: #ffffff;
        color: #353535;
        font-size: 32upx;
        line-height: 42upx;
        margin-top: 5upx;
    }

    .goods-subtitle {
        margin-top: 23upx;
        font-size: 24upx;
        line-height: 34upx;
        color: #999999;
        margin-bottom: 20upx;
    }
    .attr {
        background-color: #f7f7f7;
    }

    .recommend {
        .recommend-title {
            margin: #{40rpx} 0 #{32rpx} 0;
            font-size: $uni-font-size-weak-one;
            color: $uni-general-color-two;

            .border {
                border-top: #{1rpx} solid #bbbbbb;
                height: 0;
                width: #{40rpx};
                margin: 0 #{24rpx};
            }

            image {
                width: #{24rpx};
                height: #{24rpx};
                display: block;
                margin-right: #{12rpx};
            }
        }
    }

    .u-bottom-height {
        height: 110upx;
    }

    .bd-bottom {
        width: 750upx;
        height: 110upx;
        padding: 20upx 24upx;
    }

    .bd-back {
        width: 66upx;
        height: 100%;
        margin-right: 20upx;
    }
    .bd-icon {
        width: 30upx;
        height: 30upx;
        margin-bottom: 8upx;
    }
    .bd-text {
        font-size: 20upx;
        color: #888888;
        line-height: 1;
    }
    .bd-btn {
        text-align: center;
        line-height: 70upx;
        font-size: 28upx;
        border-radius: 35upx;
    }
    .bd-btn-left {
        border-top-right-radius: 0;
        border-bottom-right-radius: 0;
    }
    .bd-btn-right {
        border-top-left-radius: 0;
        border-bottom-left-radius: 0;
    }
    .bd-btn-half {
        width: 50%;
    }
    .bd-btn-color {
        color: #ffffff;
    }
    .bd-oversell-btn {
        background-color: #CDCDCD;
    }
    .comments {
        margin-bottom: #{20rpx};
        background-color: #ffffff;
    }

    .detail {
        background-color: #ffffff;

        image {
            width: 100%;
            height: #{80rpx};
            display: block;
        }
    }

    .price {
        font-size: #{40rpx};
        color: #ff4544;
        font-family: Alibaba;
        background-color: #fff;
        position: relative;
    }

    //.price image {
    //    height: #{44rpx};
    //    width: #{44rpx};
    //    display: block;
    //    float: left;
    //    margin-right: #{16rpx};
    //}

    .share {
        height: #{48rpx};
        border-radius: #{40rpx} 0 0 #{40rpx};
        padding: 0 #{14rpx};
        width: #{103rpx};
        margin-right: #{-20rpx};

        .share-image {
            width: #{22rpx};
            height: #{22rpx};
        }
        .share-text {
            font-size: #{22rpx};
            color: #ffffff;
            margin-left: #{10rpx};
        }
    }

    .original {
        background-color: #fff;
        text-decoration: line-through;
        color: #888;
        height: #{60rpx};
        line-height: #{60rpx};
        font-size: #{24rpx};
    }
    .u-bottom-fixed {
        position: fixed;
        bottom: 0;
        left: 0;
        width: 100%;
        z-index: 1602;
        background-color: #ffffff;
    }
</style>
